package com.ruoyi.course.domain;

import java.math.BigDecimal;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.baomidou.mybatisplus.annotation.TableName;
import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.BaseEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.ToString;
import lombok.experimental.Accessors;


/**
 * 考试班次对象 exam_class
 *
 * @author Tellsea
 * @date 2025-09-26
 */
@Data
@Accessors(chain = true)
@ToString(callSuper = true)
@EqualsAndHashCode(callSuper = true)
@TableName("exam_class")
public class ExamClass extends BaseEntity {

    /**
     * 主键ID
     */
    private Long id;

    /**
     * 班次名称
     */
    @Excel(name = "班次名称")
    private String className;

    /**
     * 班次编码
     */
    @Excel(name = "班次编码")
    private String classCode;

    private Long categoryId;

    /**
     * 开始时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "开始时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date startTime;

    /**
     * 结束时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "结束时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date endTime;

    /**
     * 报名开始时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "报名开始时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date registerStartTime;

    /**
     * 报名结束时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "报名结束时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date registerEndTime;

    /**
     * 考试时长（分钟）
     */
    @Excel(name = "考试时长", readConverterExp = "分=钟")
    private Long examDuration;

    /**
     * 原价
     */
    @Excel(name = "原价")
    private BigDecimal originalPrice;

    /**
     * 现价
     */
    @Excel(name = "现价")
    private BigDecimal currentPrice;

    /**
     * 是否免费（0否，1是）
     */
    @Excel(name = "是否免费", readConverterExp = "0=否，1是")
    private Integer isFree;

    /**
     * 班次描述
     */
    @Excel(name = "班次描述")
    private String classDescription;

    /**
     * 班次管理人
     */
    @Excel(name = "班次管理人")
    private String classManager;

    /**
     * 联系方式
     */
    @Excel(name = "联系方式")
    private String classContact;

    /**
     * 显示顺序
     */
    @Excel(name = "显示顺序")
    private Long sortOrder;

    /**
     * 班次状态（0正常、1停用、2结束）
     */
    @Excel(name = "班次状态", readConverterExp = "0招生、1考试、2结束")
    private Integer status;

    /**
     * 是否公开（0否，1是）
     */
    @Excel(name = "是否公开", readConverterExp = "0=否，1是")
    private Integer isPublic;

    //is_featuredtinyint(1)是否为精选（0否，1是）
    // @Excel(name = "是否为精选", readConverterExp = "0=否，1是")
    private Integer isFeatured;

    private String coverImage;

}
